<!-- 横向布局 -->
<template>
	<el-container class="layout">
		<el-header>
			<div class="logo flex-center">
				<img class="logo-img" src="@/assets/images/logo.png" alt="logo" />
				<span class="logo-text">Base Admin</span>
			</div>
			<el-menu mode="horizontal" :default-active="activeMenu" :router="false" :unique-opened="true">
				<!-- 不能直接使用 SubMenu 组件，无法触发 el-menu 隐藏省略功能 -->
				<template v-for="subItem in menuList" :key="subItem.path">
					<el-sub-menu v-if="subItem.children?.length" :key="subItem.path" :index="subItem.path + 'el-sub-menu'">
						<template #title>
							<el-icon v-if="subItem.meta.icon">
								<component :is="subItem.meta.icon"></component>
							</el-icon>
							<span>{{ subItem.meta.title }}</span>
						</template>
						<SubMenu :menu-list="subItem.children" />
					</el-sub-menu>
					<el-menu-item
						v-else
						:key="subItem.path + 'el-menu-item'"
						:index="subItem.path"
						@click="handleClickMenu(subItem)"
					>
						<el-icon v-if="subItem.meta.icon">
							<component :is="subItem.meta.icon"></component>
						</el-icon>
						<template #title>
							<span>{{ subItem.meta.title }}</span>
						</template>
					</el-menu-item>
				</template>
			</el-menu>
			<ToolBarRight />
		</el-header>
		<Main />
	</el-container>
</template>

<script setup lang="ts" name="layoutTransverse">
import { computed } from "vue";
import { useAuthStore } from "@/stores/modules/auth";
import { useRoute, useRouter } from "vue-router";
import Main from "@/layouts/components/Main/index.vue";
import ToolBarRight from "@/layouts/components/Header/ToolBarRight.vue";
import SubMenu from "@/layouts/components/Menu/SubMenu.vue";

const route = useRoute();
const router = useRouter();
const authStore = useAuthStore();
const menuList = computed(() => authStore.showMenuListGet);
const activeMenu = computed(() => (route.meta.activeMenu ? route.meta.activeMenu : route.path) as string);

const handleClickMenu = (subItem: Auth.MenuProps) => {
	router.push(subItem.path);
};
</script>

<style scoped lang="scss">
@import "./index.scss";
</style>
